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(54) Electronic notebook for maintaining design information 

(57) An electronic notebook for nraintaining design 
information maintains information corresponding to a 
design, and follows the steps of receiving a request to 
add note information corresponding to the design, and 
automatically copying, in response to the request, at 
least a portion of the design to a note of the electronic 
notebook. 
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Description 

BACKGROUND OF THE iNVENTION 

Field olihe Invention 5 

[00011 The presart invention pertains to the field of 
data storage. More particularly, this invention relates to 
maintaining design information. 

70 

Background 

[0002] As technoiogy has advanced, computer sys- 
tems have become more and more comnrtonplace in a 
wide variety of home and knisiness environments. One is 
use of such computer systems is for computer aided 
design (CAD) programs, which allow users to design 
various products in varying degrees of detail. Although 
modem CAD programs provide excellent drawing capa- 
bilities, their ability to track the design intent of the 20 
designer(8) as well as the history of a design are virtu- 
ally nonexistent. 

[0003] One solution to this problem is for the user to 
manually document the design intent and history in a 
separate text document, such as by using a word proc- 25 
essor or text editor. However, this solution does not 
allow the text document and the corresponding design 
to be linked. In other words, there is no direct indication 
in the design of which portions of the design are further 
discussed in the separate text document. 30 
[0004] Solutions to similar problems in other applica- 
tion areas include, for example, the ability provkfed by 
some word processors for a user to insert comments 
into a text document. An indication of where these conv 
ments occur within the text is typically displayed to the 
user (e.g., a comment number or high-lighting Of a por- 
tion of the text). However, one problem with such com- 
ments is that they must accompany the underlying 
document. That is. there is typically no ability to view the 
comments separately from the underlying document 
Another problem with such comments is that their con- 
tent is typically only that which is manually entered by 
the user. That is. there is typically no ability to automat- 
ically enter portion(s) of an unda*lying document into 
the comments. 

[0005] Another solution in other application areas 
includes the ability to link and/or embed documents into 
a word processing document, generally referred to as 
"Ol-E" (object linking and emt)edding). However, prob- 
lems similar to those with comments exist with OLE, 
such as the linking and/or emt)edding having to be done 
manually by the user. Similarly, OLE limits a user to 
inputting only a single representation or view of a docu- 
ment (e.g., the first few cells of data from a spreacteheet) 
into the word processing document - multiple views are 
not poss^e. 

[0006] Thus, a need exists for an improved way to 
track design intent and deagn history. 



SUMMARY OF THE INVENTION 

[0007] An electronic notebook for maintaining design 
information is desaibed herein. The electronic note- 
book maintains infomiation corresponding to a design, 
following the st^ of receiving a request to add note 
information corresponding to the design, and automati- 
cally copying, in response to the request, at least a por- 
tion of the design to a note of the electronic notebook. 
[0008] According to one embocfiment of the present 
invention, in response to the request primary design 
information is automatically added to the note. Addition- 
aQy, In this entxxJiment. secondary design information 
can be added to the note by the user. 
[0009] Accorc£ng to one emtKxfiment of the present 
invention, primary or secondary design information 
added to a note includes one or more of text data, audio 
data, and video data 

[0010] According to one embodiment of the present 
invention, at least a portion of the design added to the 
note is a "snapshot" of the cun-ent state of the design. 
[001 1 ] According to one embodiment of the present 
invention, at least a portion of the design added to the 
note is a dynamic object which is updated, each time 
the note is accessed, in order to reflect the most recent 
state of the design. 

[0012] Accorc£ng to one embodiment of the present 
invention, multiple views of a design can be Included 
within a sirigle note. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0013] The present invention is illustrated by way of 
example and not limitation in the figures of the accom- 
panying drawings, in which like references indicate sim- 
ilar elements and in which: 

Rgure la is a simplified block diagram illustrating 
an example computer system architecture including 
an electronic notebook according to one emkxxti- 
ment of the presait invention; 
Rgure 1b is a simplrfied block diagram illustrating 
an example computer system architecture including 
an electronic notetxx)k according to another 
emtxxliment of tiie present invention; 
Rgure 2 is a block diagram illustrating an electronic 
notebook in more detail accorcfing to one embodi- 
ment of the present invention; 
Rgure 3 illustrates an example display of a design 
such as n^y be used witii one emtxxliment of the 
present invention; 

Rgure 4 illustrates an example display oif a note 

within an electronic notebook according to one 

emtxxJiment of the present invention; 

Rgure 5 illustrates an electronic notebook <^ta- 

base according to one emtxxfiment of the present 

invention; 

Rgure 6 is a flowchart illustrating the steps followed 
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in adding information to a note of an electronic 
not^xwk according to one emtxxliment of the 
present invention; and 

Figure 7 illustrates an example hardware system 
suitat>le for use with one embodiment of the present 
invention. 

DETAILED DESCRIPTION 

[C01 4] In the following detaOed description numerous 
specific details are set forth in order to provide a thor- 
ough understanding of the present invention. However, 
it will be understood by those skilled in the art that the 
present invention may be practiced without these spe- 
cific details. In other instances well known methods, 
procedures, components, and circuits have not been 
described in detail so as not to obscure the present 
invention. 

[0015] Some portions of the detailed descriptions 
which follow are presented in terms of algorithms and 
symbolic representations of operations on data bits 
within a computer memory. These algorithmic descrip- 
tions and representations are the means used by those 
skilled in the data processing arts to most effectively 
convey the substance of their work to others skilled in 
the art. An algorithm is here, and generally, conceived 
to be a self-consistent sequence of steps leading to a 
desired result. The steps are those requiring physical 
manipulations of physical quantities. Usually, though not 
necessarily, these quantities take the form of electrical 
or magnetic signals capable of being stored, trans- 
ferred, combined, compared, and othenwise manipu- 
lated. It has proven convenient at times, principally for 
reasons of comn^on usage, to refer to these signals as 
bits, values, elements, symbols, characters, terms, 
numbers, or the like. It should be borne in mind, how- 
ever, that all of these and similar terms are to be associ- 
ated with the appropriate physical quantities and are 
merely convenient lat>els applied to these quantities. 
Unless specifically stated otherwise as apparent from 
the following discussions, it is appreciated that through- 
out the present invention, discussions utilizing terms 
such as "processing" or "computing" or "calculating" or 
"determining" or "displaying" or the like, refer to the 
action and processes of a computer system, or similar 
electronic computing device, that manipulates and 
transforms data represented as physical (electronic] 
quantities within the computer system's registers and 
memories into other data similariy represented as phys- 
ical quantities within the computer system memories or 
registers or other such information storage, transmis- 
sion or display devices. 

[0016] Rgure 1 a is a simplified block diagram iDustrat- 
ing an example conputer system architecture including 
an electronic notebook according to one embodiment of 
the pr^nt invention. As illustrated, system architecture 
ICQ includes an operating system 110. a basic input 
output system (BIOS) 120. a design application 130. 



and an electronic notetx>ok 140 of the present inven- 
tion. 

[001 7] Rgure 1 b is a simplified block diagram illustrat- 
ing an example computer system architecture including 

5 an electronic notebook according to another embodi- 
ment of the present invention. As illustrated, system 
architecture 150 includes operating system 110. BIOS 
120. design application 130. and electronic notebook 
140, each of which performs the same functions as in 

10 system architecture 100. However, system architecture 
150 of Rgure 1 b differs from system architecture 1 00 of 
Rgure la in that electronic notebook 140 is incorpo- 
rated into and operates as part of design application 
130, rather than as a standalone application. 

IS [0018] BIOS 120 provides an irrterface between oper- 
ating system 110 and the various input/output (1/0) 
devices coupled to the system. Operating system 1 1 0 is 
a software application which provides an interface 
t»etween BIOS 120 and software applications such as 

20 electronic notebook 140 and design application 130. It 
is to be appreciated that additional applications (not 
shown) may also be executed under the control of oper- 
ating system 110. Operating system 110 provides an 
internee, such as a graphical user interface (GUI). 

25 between the user and the applications executing on the 
conputer system. According to one embodiment of the 
present invention, operating system 110 is the Win- 
dows^ 95 operating system, available from Microsoft 
Corporation of Redmond, Washington. However, it is to 

30 be appreciated that the present invention may be used 
with any other conventional operating system, such as 
other versions of Miaosoft Windows^ (for example. 
Windows™ 3.0, Windows™ 3.1, Windovre™ NT, or Win- 
dows™ CE) or Microsoft DOS, OS/2, available from 

35 International Business Machines Corporation of 
Armonk. New York, or the Apple Macintosh Operating 
System, available from Apple Computer Incorporated of 
Cupertino. California. It is also to be appreciated that in 
alternate embodiments various portions of operating 

40 system 110 can be implemented in hardware and/or 
firmware. 

[001 9] Design application 1 30 is intended to represent 
any of a wide variety of commercially available applica- 
tions to assist a user in the design of something, such 

45 as a product (mechanical and/or electrical), a structure 
(e.g., a house or office building), computer software, 
etc. According to one implementation, design applica- 
tion 130 is a computer-aided design (CAD) program, 
such as one of the AutoCAD® or Mechanical Desktop® 

50 family of software applications available from Autodesk. 
Inc. of San Rafael, California. However, in alternate 
implementations design application 130 can be other 
design products, such as a circuit design and/or simula- 
tion program, software development environment etc. It 

55 is to be appreciated that the specific functions provided 
by design application 130 are dependent on the specific 
software application being used. 
[0020] Electronic notebook 140 of the present inven- 
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tion is an application used to maintain design infonna- 
tion for designs created by another application, such as 
design application 130. Electronic notebook 140 advan- 
tageously maintains design information through at least 
in part automated transfer of selected portions of the 
design from design application 130. providing an inte- 
grated environment for design and design note-taking. 
Electronic notebook 1 40 ^ discussed in more detail with 
reference to the following Rgures. 
[0021] Figure 2 is a block diagram illustrating elec- 
tronic notebook 140 in more detail according to one 
embodiment of the present invention. As illustrated, 
electronic notebook 140 includes notebook database 
252, main control logic 250, text view control logic 248. 
graphics view control logic 246, browser control logic 
244, markup control logic 242. and "other" control logic 
240. The operation of electronic notebook 140 will be 
discussed below with reference to the example displays 
of Figures 3 and 4. 

[0022] Figure 3 illustrates an example display of a 
design and accompanying information by design appli- 
cation 130 of Figure la or lb. A wirxiow 300 is illus- 
trated including a title bar portion 310, a browser portion 
320. and a graphics portion 340. Title bar portion 310 
includes an identifier 312 of the design, ("block" as illus- 
trated), as well as controls 314 for nninimizing. maximiz- 
ing, and dosing the window 300. The use of such 
controls 314 are well known to those skilled in the art 
and thus will not be discussed further. 
[0023] Browser portion 320 identifies different 
"pieces" of the design identified by identifier 312 which 
can be viewed by the user. Additionally, in one embodi- 
ment an identification of the notes from electronic note- 
book 140 which can be viewed by the user is also 
displayed in browser portion 320. such as notes 322 
and 324. As will be appreciated by those skilled in the 
art, various features of the design 342 within graphics 
portion 340 can be selected by a user. Examples of 
such features include, faces, edges, combinations 
thereof (e.g., extrusions, holes), etc. 
[0024] Figure 4 illustrates an example display of a 
note within an electronic notetjook according to one 
embodiment of the present invention. As illustrated, a 
window 400 includes windows 405 and 410. Each of the 
windows 400, 405, and 410 includes a title bar with an 
identifier, as well as window controls to minimize, maxi- 
mize, and dose their respective windows. Additionally, 
window 400 indudes a toolbar 401 . format bar 402, and 
menu bar 403. Toolbar 401 indudes various 'tools", 
such as cut, paste, copy, print, save, help, etc. which 
can be selected by the user. Format bar 402 irtdudes 
various text formatting and alignment options, such as 
font type, font size. bold, italics, underline, left justify, 
center, etc. which can be selected by the user. I^enu bar 
403 indudes various command menus, such as fOe 
commands, editing commarvjs, viewing options, etc. 
which can be selected by the L£er. The use of such 
"tools", menus, and text formatting/alignrnwit options 
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are well known to those skilled in the art and thi^ will 
not be (fiscussed hirther except as they pertain to the 
present invention. 

[0025] Window 405 indudes a browser portion 440. 

5 and a note portion 445. In the illustrated implementa- 
tion, note portion 445 is displayed to simulate a conven- 
tional spiral bound paper notebook. Note portion 445 
includes a graf^ics portion 447, a text portion 449. and 
a "markup" 451. 

10 [0026] Returning to Figure 2, the notetK>ok database 
252 stores the note(s) of electronic notebook 140, such 
as note 445 of Figure 4. Each of the notes within the 
database 252 can indude any one or more of the follow- 
ing: text areas, graphics areas, markup areas, and 

}5 "other areas. Each of these areas is discussed in more 
detail below. In the illustrated embodiment, notebook 
database 252 is shown as being contained within elec- 
tronic notebook 140. However, in aKernale embodi- 
ments, notebook database 252 can be incorporated 

20 into, and thus be stored with, the design database(s) of 
design application 130. 

[0027] Graphics view control k)gic 246 manages the 
d^ay of a design, such as a design created by design 
application 130. within a note. During creation of the 

2S note, or the adding of additional graphics areas to a pre- 
existing note, graphics view control 246 manages the 
display of the current view of a design as well as any 
rotation of the design requested by the us^. A view of 
the design object 342 of Figure 3 is illustrated as object 

30 457 in Figure 4. 

[0028] According to one embodiment of the present 
invention, during creation of the note 445, the object 
457 can be rotated through multiple views to any one of 
a plurality of views. This rotation can be in one or more 

35 dimensions, and is three-dimensiorBl in one implemen- 
tatioa Additionally, the object 457 can be manipulated 
in various other manners, induding "zooming" in and 
out on the object "panning" around the object, etc. The 
rotation and other manipulation of the object 457 can be 

40 accomplished in any of a wide variety of conventional 
manners based on any of a wide variety of conventional 
modeling techniques. Such modeling techniques are 
well-known to those skilled in the art and thus wiD not be 
discussed further except as they pertain to the present 

45 invention. The rotation may be incficated by a user in any 
of a wide variety of conventional manners, such as 
selection of a tod button from toolbar 401, selection of 
a menu item from menu bar 403, or selection of a menii 
item from a pull down menu when object 457 is selected 

50 (for example, by right "diddng" on a cursor control 
device while the cursor is "on top" of objed 457). 
[0029] According to one emtiodiment of the present 
invention a user "freezes" the cun-ent data of the object 
342 and stores the "frozen" data in notebook database 

55 2^. This Trozen" or "snapshot" data is the data of the 
ot^ect 342 at the time it is frozen - subsequent changes 
to the object 342 by the user of design application 130 
do not affect the object 457 of electronic notebook 140. 
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The ^zen" data can be stored in notebook database 
252 using any of a wide variety of conventional man- 
ners, such as in a vector format wherein each feature or 
part of the object 457 is identified by one or more vec- 
tors. 5 
[0030] The frozen data can be further rotated and/or 
manipulated by the user (zoomed, etc.) so that a partic- 
ular 1)rimary'' view of the object is being displayed. The 
primary view can be selected by the user in any of a 
wide variety of manners, such as by selection of a "save io 
view" menu item when the object 457 is rotating, or by 
entering In specific degrees of rotation and zoom 
amounts (ag.. 50%. 200%. etc.). An identrfication of this 
primary view is then stored in notebook datat)ase 252 
so that when the note is sut>sec|uently accessed (e.g.. is 
opened, printed, etc.), the primary view wilt be provided. 
It is to be appreciated, however, that a user can still 
rotate and/or othennnse manipulate the object after this 
primary view is selected. 

[0031 ] It should be noted that multiple graphics areas 20 
can be included within a single note, and thus that mul- 
tiple views of the same ol:^ect can be frozen by a user 
within a single note. Thus, by way of example, a user 
could include two or more objects 457 in the note, each 
having different primary views and/or being different 2S 
versions of the object 342. Thus, the history of a partic- 
ular design can be advantag^usly tracked by the elec- 
tronic notebook 140 staing different data for the same 
object over time, and allowing additional information 
(text, audio, video, etc.) to be added to help explain the 30 
history. 

[0032] In the illustrated embodiment, a particular part 
of the object 457 is highlighted within the note 445. The 
particular part which is highlighted is the same feature 
or part of object 342 which was selected in design appli- 35 
cation 130 when the user indicated to create (or add to) 
the note. These parts can include any one or more 
faces, edges, vertices or combinations thereof (for 
example, holes or extrusions). In the example note 445 
of Figure 4, the face 459 of object 457 is highlighted. It 40 
is to be appreciated that this highlighting can be per- 
formed in any of a wide variety of conventional matters, 
including altering the appearance of the entire feature or 
an outline of the feature; by altering, for example, the 
color of such feature or outline. Thus, it can k>e seen that 45 
a note corresponds to an object and can also corre- 
spond to a particular part of that object as irniicated by 
the highlighting. In alternate embodiments of the 
present inventioa graphics view control 246 allows a 
user to further highlight additional parts or features of so 
object 457 within the note 445. 
[0033] According to an alternate embodiment, the 
note includes dynamic rather than static data for display. 
Static data is "frozen" data as discussed above. 
Dynamic data, however, is updated by graphics view 55 
control 246 each time the note is accessed, or alterna- 
tively when a "refresh** selection is made by a user. In 
this alternate embodiment, notebook database 252 
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maintains a record of the location of the object 342 (e.g. , 
a location of a data file descrit^ng the object and a 
rame of the object within that ffle). In this embodiment, 
graphics view control 246 is programmed with the for- 
mat in which the image is stored by design application 
130. and thus is able to interpret the image's data file 
and properiy display the image. Thus, whenever the 
note 445 is accessed, graphics view control 246 
accesses the location of the object and retrieves a cur- 
rent version of the object 342. It should be noted that the 
location from which the object is retrieved can be local 
(e.g., on the same machine as the electronic notebook 
140 is currently executing), or remote (e.g.. over a net- 
work such as a local area network (LAN) or the Inter- 
net). 

[0034] Text view control 248 manages the display of 
text areas of a note, both during creation of the note and 
during subsequent viewing of the note. Upon creation of 
a note, text view control 248 automatically enters into 
the note primary design information corresponding to 
the design. In the illustrated embodiment this primary 
design information (information 453 of Figure 4) 
includes an identifier of the user ("Smith*^ which created 
the cunent text area 449 as well as the date ("1/1/98*') 
on which the text area 449 was aeated. However, in 
alternate embodiments different primary design Infor- 
mation, including text as well as other media (e.g.. audio 
or video), can be entered. Additionally text view control 
248 allows a user to enter into the note secondary 
design information conesponding to the design. It is to 
be appreciated that because this secondary design 
information Is input by the user, the scope and content 
of the secondary design information can vary greatly In 
the example of Figure 4. secondary design information 
455 is user-input text which desaibes why the kJentif led 
surface of the product was designed in a particular way 
/Additionally, according to one en^xxliment of the 
present invention, text view control 248 provides various 
conventional text formatting options to the user. Exam- 
ples of such text formatting include 'red-lining** of 
deleted text and otiier representations of text editing, 
setting font size and type, bolding. italicizing, or other- 
wise higfilighting sections of text. etc. In alternate 
emtxxliments of the present invention, eitiier one or 
both of the primary design information and the second- 
ary design information are optional. 
[0035] Browser control 244 manages the display of 
note icons in browser portion 440 of Figure 4. including 
control of the layout within the browser portion 440. 
Browser control 244 also provides a user witt) the ability 
to change names of notes, select particular notes for 
display (for example, by *'double-clicking*' on the notes), 
and reorganize the display of note icons on the display 
device (e.g.. in a "drag and drop" manner). 
[0036] According to one en*odiment of ttie present 
invention, note identifiers as well as Identifiers of the 
parts to which ttie notes correspond are provided to 
design application 130. This allows design application 
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130 to include the note identifiers in its own browser 
window, such as window 410 of Figure 4. Selection 
(e.g., "doidale-dickingT on a note identifier within win- 
dow 410 causes design application 130 to notify elec- 
tronic notebook 140 of the selected note identifier, in 
response to which electronic not^xwk 140 displays the 
corresponding note. Thus, in this embodiment two sep- 
arate browsers (the browser provided by design appli- 
cation 130 and the browser provided by electronic 
notebook 140) are usable by the viewer to access the 
notes of electronic notebook 140. 
[0037] "Other control logic 240 manages the presen- 
tation of other areas of secondary information within a 
note. Such "other" areas are separate from the text area 
449 arxJ graphics area 447 and can include different 
types of media. Examples of such media provided in the 
"other** areas include: audio information, video informa- 
tion, data from other applications (for example, word 
processing documents or spreadsheets), etc. Data from 
other applications can be copied into the note, or alter- 
natively a pointer to another file (e.g. . a word processing 
file or a spreadsheet file) can be stored within the note 
and the file subsequently accessed by electronic note- 
book 1 40 when the note Is accessed- It is to be appreci- 
ated that the manner in which such "other" media is 
provided is dependent on the particular medium. By 
way of example, video Information may be displayed 
within another area of note 445, whereas audio informa- 
tion may be played when the note 445 is accessed, or 
alternatively when a particular "audio" icon (not shown) 
on the note 445 is displayed. 
[0038] Markup control logic 242 manages the display 
of any "markups" within the note. As used herein, a 
"markup" refers to a connection t)etween two or more 
text, graphics, or other areas of a note. According to one 
embodiment of the present convention, these connec- 
tions are identified to a user as a visual or graphical con- 
nection in the note, such as anow 451 of Figure 4. 
[0039] Main control 250 manages the interaction 
among text view control 248. graphics view control 246, 
browser control 244, markup control 242, "other" control 
240. and notebook database 252. Main control 250 also 
maintains notebook database 252, adding new notes 
and modifying notes within database 252 as requested 
by the user. Main control 250 is also responsible for 
managing the coordinated display of the graphics sec- 
tions, text sections, and other areas of a note. In other 
words, main control 250 controls where, within a note, 
each of the one or more possaale text, graphics, and 
"other" areas is to be located. 

[0040] According to one emlxxliment of the present 
invention, electronic notelx>ok 140 is implemented in 
software. However, in alternate OTt)0diments one or 
more portions of electronic notebook 1 40 can be imple- 
mented in hardware and/or finnware. 
[0041] According to one embodiment of the present 
invention, electronic notebook 140 is a stand-alone 
application which executes independently of design 



application 130. Although, as discussed al)ove, the 
electronic notebook 140 may obtain current view infor- 
matiOT regarding a design from the database(s) of 
design application 130. the two applications are none- 

5 theless executed s^rately by operating system 1 10. 
Furthermore, it to be appreciated that in embodi- 
ments which use static graphics areas, the notes within 
electronic notebook 140 can be viewed after their crea- 
tion independently of the design application and Its 

10 database(s). Thus, for exanrple, a stand-alone elec- 
tronic notebook 140 can be executed at another compu- 
ter system which does not include design application 
130. 

[0042] According to another embodiment of the 

15 preswTt invention, the electronic notebook 140 operates 
in conjunction vinth design application 130. In this 
embodiment main control 250 receives input from 
design application 130 of the current object and cun^ent 
view of that object being displayed witWn virindow 300 of 

20 Figure 3. Main control 250 accesses notebook data- 
base 252 to determine whether the electronic notebook 
1 40 includes any notes corresponding to the object cur- 
rently displayed by design application 130, and H so, 
which feature(s) of the objects have notes associated 

25 with them. The features with notes can be identified by 
determining which features of an object are highlighted 
within a note. If an object has a corresponding note, 
then a note "glyph" is displayed along with the object, 
such as "glyph" 347 of Rgure 3. 

30 [0043] The design application 130 is then able to 
maintain a record of which feature(s) of an object have 
notes associated with ttiem. According to one embodi- 
ment of the present invention, if the note corresponds to 
a particular feature of the object then the "glyph" 347 is 

35 displayed on that particular feature. In this embodiment, 
the design application 130 maintains a record of which 
view orientations display the feature, and thus which 
view orientations should include the "glyph". In alternate 
embodiments, the "glyph" 347 is located in differem 

40 screen locations, either "on top oT or separate from the 
object. 

[0044] According to one embodiment the "glyph" 347 
is displayed along the edge or boundary of the selected 
part. In one implementation, the "glyph" 347 is dis- 
45 played along the boundary of the part at the point hav- 
ing the greatest "xyz" value {corresponding to, for 
example, the largest sum of x, y, and z dimensions of 
the t>oundary). However, alternate implementations 
place the "glyph" 347 in other points along the boundary 
so of the part 

[0045] Additionally, according to one embodiment of 
the present invention, design application 130 displays 
one or more areas of the note con-esponding to a partic- 
ular feature when the user places the cursor "on top" of 
55 the "glyph" for that feature. Design application 130 
sends a request to main control 250 of Rgure 2 to 
retrieve the data from a particular area (e.g., the text 
area 518 data of Rgure 5) for the proper note. Design 
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application 130 then displays the retrieved data on the 
screen for so long as the cursor is "on top" of that 
"glyph^ 

[0046] Additionally, in embodiments where electronic 
notebook 140 operates in conjunction with design appli- 
cation 130, identifiers of the notes stored in notebook 
database 252 can be dsplayed in a browser window of 
design application 130. For example, design application 
130 can display the notes 461 in window 410 of Figure 
4, along with the part or object list of the design. 
[0047] Figure 5 Illustrates an ^ectronic notebook 
datat)ase according to one enrttxvdiment of the present 
invention. In the illustrated embodiment the database of 
Rgure 5 is database 252 of Figure 2. Database 252 is 
illustrated as storing a single notetxok 502. However, It 
IS to be appreciated that in alternate embodiments, 
additional notek)ooks 502 corresponding to the same or 
different designs, or to different design applications, can 
be included within database 252. 
[0048] As illustrated, notebook 502 includes muttipte 
(N) notes 510 and 540. Note 510 includes markup data 
512 and note area data 514. Markup data 512 includes 
data identifying one or more connections to be made 
between two or more of the areas of the note. Note area 
514 Includes data identifying the text, graphics, and 
"other" contents of the note, and is comprised of one or 
more graphics areas 516, text areas 518. and "other" 
areas 520. 

[0049] Graphics areas 516 include data identifying the 
object data of a design, or a poirrter to the object data of 
a design, to be displayed within the note by graphics 
view control 246 of Rgure 2. An indication of the "pri- 
mary" view of the object is also stored in graphics areas 
516. Graphics areas 516 also include selected format- 
ting optk)ns, such as a particular feature being high- 
lighted, n shoukl be noted that one or more graphics 
areas 516 can be included within a single note 510, 
thereby allowing the history of a particular object's 
development to be tracked in a single note. 
[0050] Similarly, text areas 518 store the primary 
and/or secondary design information to be provided in 
the note by text view control 248. Text areas 518 also 
store various formatting options for the primary and sec- 
ondary design information. It is to be appreciated tfiat 
multiple text areas 518 can exist within a single note. 
[0051] The "other" areas 520 store data identifying 
various other secondary information which can be pro- 
vided in the note by "other^ control 240 of Figure 2. 
Examples of such "other" secondary information 
include audio data (for example, ".wav" fDes), video data 
(for example. JPEG files), as well as other "text" files (for 
example, word processing documents, the spreadsheet 
documents, etc.). The actual data for these "other" 
types of files may be stored within "other" areas 520, or 
attematively an identifier of where the data can be 
located (e.g., a filename and path) may be stored within 
"other" areas 520. It is to be appreciated that multiple 
"other" areas 520 can be included within a single note 
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510. 

[0052] Similar data storage areas exist within note 
540. as illustrated in Rgure 5. 
[0053] It is to be appreciated that the notebook data- 
5 base 252 can be implemented using any of a wide vari- 
ety of oonventiona] data structures. By way of example. 
datat)ase 252 can be implemented using linked lists 
and/or arrays. 

[0054] According to one enrdsodiment of the present 
10 invention, the object 457 of Rgure 4 is stored by elec- 
tronic not^xx>k 140 using sut)StantiaOy the same data 
^cture as is used by design application 130 to store 
object 342 of Rgure 3. However, in an alternate embod- 
iment, electronic notebook 140 uses a different data 
15 Structure and translates between the two data struc- 
tures as necessary. 

[0055] Additionally, according to one embodiment of 
the present invention electronic notebook 1 40 uses sub- 
stantially the same data rotation and/or manipulation 

20 processes as are employed by application 1 30 to rotate 
and/or manipulate the data. However, in alternate 
embodiments, different data rotation and/or manipula- 
tion processes are used by electronic notebook 140. 
[0056] Figure 6 is a flowchart illustrating the steps fbl- 

25 lowed in adding information to a note of an electronic 
notdsook according to one emtxxiiment of the present 
invention. As illustrated, a note request is received by 
main control 250 of Rgure 2. step 605. The note request 
is a request to add note information for any one or vnore 

30 areas (e.g.. text, graphics, or "other" areas, or a 
markup) corresponding to an object. The request 
includes an indication of which feature of design 342, if 
any, was selected when tiie request was made. In the 
illustrated embodiment, the request Is made by a user in 

35 any of a wide variety of conventional manners (e.g., 
selecting a "new note" or "modify note" command from 
a pull down menu when "clicking" on a feature of the 
design 342). 

[0057] Upon receipt of the request, main control 250 

40 Checks whether it is a request for a new note, step 61 0. 
If rt is not a request to create a new note, then main con- 
trol 250 accesses the note identified In the request in 
notdxx)k datat>ase 252. step 615. Main control 250 
then proceeds to step 625. However, if the request is a 

45 request for a new note, then main control 250 aeates a 
new note data sti^ucture 620, then proceeds to step 625. 
[0058] In step 625, main control 250 copies the cur- 
rent object data into the note identified by the request 
(either the newly aeated or tiie accessed note). Main 

50 control 250 then automatically enters primary design 
infonnation (e.g.. an identifier of tiie user that made tiie 
request and the date on which tiie request is made), 
step 630. As illustrated in Rgure 6. both steps 625 and 
630 are optioial. Thus, in alternate emtxxliments. tiie 

55 cun-ent drawing need not be copied into the note in step 
625 and the prinwy design information need not be 
copied into the note in step 630. 
[0059] Main control 250 then checks whettier second- 
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ary design irtformation been received from the user, 
step 635. If secondary design information has been 
received then main control 250 stores the secondary 
design information as part of the note in datat}ase 252, 
step 640. 

[0080] Processing then continues from step 635 or 
step 640 to st^ 645, where n^n control 250 checks 
whether a markup request has been received, tf a 
markup request has been received then main control 
250 stores the markup as part of the note in database 
252. step 650. 

[0081] Processing then continues from step 645 or 
step 650 to step 655. where main control checks 
whether a rotation request is received from the user. If a 
rotation request has been received, th&i main control 
250 forwards the request to graphics view control 246 to 
rotate the object in the requested manner, step 660. 
[0082] Processing then continues from step 655 or 
step 660 to step 665, v/here main control checks 
whether a "save" note request has been received, step 
665. Main control 250 continues to ^xlate the note with 
new secondary design infonrtation. markup information, 
and rotation changes, steps 635 * 665. until a "save" 
note request is received. The "save" note request indi- 
cates that the user is f inished entering data to the note 
for the present time. Thus, main control 250 saves the 
note in response to the "save" note request, step 670. 
including an indication of the view being displayed when 
the "save" note request was received (which Is stored 
as the primary view). However, it is to be appreciated 
that the user is able to add additional information to the 
note at a later time by requesting to modify the note 
(step 605). 

[0083] Figure 7 illustrates an example hardware sys- 
tem a machine suitable for use with one embodiment of 
the present invention. Hardware system 700 'includes 
processor 702 and cache memory 704 coupled to each 
other as shovm. Additionally, hardware system 700 
includes high performance input^output (I/O) bus 706 
and standard I/O bus 708. Host bridge 710 couples 
processor 702 to high performance I/O bus 706. 
whereas I/O bus bridge 712 couples the two buses 706 
and 708 to each other. Coupled to bus 706 are net- 
work/communication interface 724, system memory 
714. and video memory 71 6. In turn, display device 71 8 
is coupled to video memory 716. Coupled to bus 708 is 
mass storage 720. keyboard and pointing device 722, 
and I/O ports 726. Collectively, these elements are 
intended to represent a broad category of hardware 
systems, including but not limited to general purpose 
computer systems based on processors available from 
Intel Corporation of Santa Clara, California, from 
Advance Micro Devices (AMD) of Sunnyvale, California, 
from National SOTiconductor of Sunnyvale. California, 
or from Digital Equipment Corporation (DEC) of May- 
naid. Massachusetts. 

[0084] These elements 702 - 724 perfomi their con- 
ventional functions known in the art In particular, net- 



work/communication interface 724 is used to provide 
comnrtunicatiOT between system 700 and any of a wide 
range of conventional networks, such as an Ethernet, 
token ring, the Internet, etc. It is to be appreciated that 

5 the circuitry of irrterface 724 is dependent on the type of 
network the system 700 is being coupled to. 
[0085] Mass storage 720 is used to provide pemia- 
nent storage for the data and programming instructions 
to implement the above described functions, whereas 

10 system memory 714 is used to provide temporary stor- 
age for the cbta and programming instnjctions wh^ 
executed by processor 702. I/O ports 726 are one or 
more serial and/or parallel communication ports used to 
provide communication between additional peripheral 

15 devices which may be coupled to hardware system 700. 
[0066] It is to be appreciated tiiat various components 
of hardware system 700 nrtay be rearranged. For exam- 
ple, cache 704 may be on-chip with processor 702. 
Alternativety. cache 704 and processor 702 may be 

20 packed together as a "processor nKxiule*. with proces- 
sor 702 being referred to as the "processor core". Fur- 
thermore, certain implementations of the present 
invention may not require nor include all of the above 
connponents. For example, mass storage 720. keyboard 

25 and pointing device 722, and/or di^lay device 718 ard 
video mentory 716 may not be included in system 700. 
Additionally, the peripheral devices shown coupled to 
standard I/O bus 708 may be coupled to high perform- 
ance I/O bus 706; in addition, in some implementations 

30 only a single bus may exist with the components of 
hardware system 700 being coupled to the single bus. 
Furthermore, additional components may be included in 
system 700, such as additional processors, storage 
devices, or memories. 

35 [0067] In one embodiment, the electronic nSlebook 
according to the present invention as discussed at>ove 
is implemented as a series of software routines run 
hardware system 700 of Figure 7. In this embodiment, 
main control 250. text view control 248. graphics view 

40 control 246. browser control 244. markup control 242, 
and "other control 240 of Figure 2 are each imple- 
mented as a series of software routines. These software 
routines comprise a plurality or series of instructions to 
be executed by a processor in a hardware system, such 

45 as processor 702 of Figure 7. Initially, the series of 
instoictions are stored on a storage device, such as 
mass storage 720. It is to be appreciated that the series 
of instructions can be stored using any conventional 
storage medium, such as a diskette. CD-ROM, mag- 
so netic tape. DVD. laser cfisK ROM. Rash memory, etc. It 
is also to be appreciated tiiat the series of instructions 
need not be stored locally, and could be received from a 
remote storage device, such as a server on a network, 
via network/communication interface 724. The instruc- 

55 tions are copied from the storage device, sudi as mass 
storage 720, into memory 714 and then accessed and 
executed by processor 702. In one implementation, 
these software routines are vwritten in the C++ program- 
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ming language. It is to be appreciated, however, that 
these routines may be implemented In any of a wide 
variety of programming languages. 
[0088] In alternate embodiments, the present inven- 
tion is implemented in discrete hardware or firmware. 
For example, one or more application specific inte- 
grated circuits (ASICs) could be programmed vwth the 
above described functions of the present invention. By 
way of another exannple, main control 250. text view 
control 248, graphics view control 246, browser control 
244. markup control 242. and "other control 240 of Rg- 
ure 2 could be implemented in one or more ASICs of an 
additional circuit board for insertion into hardware sys- 
tem 700 of Figure 7. 

[0089] It is to be appreciated that although specific 
examples of primary and secondary design information, 
as well as information v»rhich can be stored in an "other" 
area, are discussed above, afternate embodiments of 
the present invention store different data. Exarrples of 
such data include: a user's intentions in nraking a 
design change; the history of the design, such as vari- 
ous modifications which were decided against or later 
changed and the reasoning behind such decisions or 
changes; assembly instructions (either for a manufac- 
turer or an end user), etc. 

[0070] Thus, the present invention provides an inte- 
grated environment for design and design note-taking. 
The electronic notebook of the present invention advan- 
tageously maintains the design information independ- 
ent of the design itself, copying over the portions of the 
design it needs in one embodiment, thereby allowing 
the electronic notebook to be used and viewed inde- 
pendently of the actual design application which aeated 
the design. Furthermore, the electronic notebook 
advantageously allows a user to maintain design intent 
and design history throughout the development and 
manufacturing of the design, as well as other informa- 
tion if desired, for the design. 
[0071] Thus, an electronic notebook for maintaining 
design information has been described. Whereas many 
alterations and modifications of the present invention 
will be comprehended by a person skilled in the art after 
having read the foregoing description, it is to be under- 
stood that the particular embodiments shown and 
desaibed by way of illustration are in no way intended to 
be considered limiting. References to details of particu- 
lar embodiments are not intended to limit the scope of 
the claims- 
Claims 

1. A method for maintaining information correspond- 
ing to a design, the method comprising: 

receiving a request to add note infornr^tion cor- 
responcfing to the design; and 
automatically copying, in response to the 
request at least a portion of the design to a 



note of an electronic not^sook. 

2. The method of claim 1 , further comprising: 

5 automatically adding to the note, in response to 

the request, primary design information con-e- 
sponding to the design, wherein the primary 
design information preferably includes a cur- 
rent date and an identifier of a current user of 

TO the design. 

3. The method of claim l , further comprising: 

receiving secondary design information oorre- 
15 sponding to tiie design ; and 

adding the secondary design information to the 
note, wherein the secondary design informa- 
tion preferably comprises one or more of audio 
data, video data, arKi text data. 

20 

4. The method of daim 3, further comprising: 

creating a graphical representation of a corre- 
spondence betweai the secondary design 
25 information and a feature of the design. 

5. The method of claim 1 . further comprising: 

rotating the at least a portion of the design 
30 through a plurality of views; 

allowing a user to select one of the plurality of 
views; and 

adding the selected view to the note as the 
design. 

35 

6. The method of claim 5. furtiier comprising: 

receiving a second request to add note infor- 
mation corresponding to the design; 
40 automatically copying. In response to the sec- 

ond request, at least a second portion of the 
design to the note of the electronic notebook; 
rotating, independentiy of the rotating of the at 
least a portion of the design, the at least a sec- 
45 ond portion of the design through a plurality of 

views of the at least a second portion; 
allowing a user to select one of the plurality of 
views of the at least a second portion; and 
adding the selected view of the at least a see- 
so ond portion to tiie note. 

7. The method of claim 1, wherein the copying com- 
prises adding a dynamic design to the note, and fur- 
tiier comprising: 

55 

accessing the design to obtain a cun-ent ver- 
sion of the design each time the note is 
accessed. 
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8. The methcxJ of daim 1 , further conrprising: 

tracking design history by autorrutticaliy copy- 
ing a plurality of portions of the design to the 
note of the electronic notebook over a period of 5 
time, each of the plurality of portions being 
from a different point in time. 

9. A machine-readable medium having stored thereon 
a plurality of instructions, designed to be executed 
by a processor, for implementing a method accord- 
ing to one of claims 1 to 8. 

10. An apparatus for maintaining information corre- 
spondir^ to a design, the apparatus comprising: 

first control logic to receive a request to add 
note information corresponding to the design; 
and 

second control logic to autonr^tically copy, in 
response to the request at least a portion of 
the design to a note of an electronic notebook. 

11. The apparatus of daim 10, wherein the second 
control logic is also to automatically add to the note, 
in response to the request, primary design informa- 
tion corresponding to the design. 



to the request at least a portion of the design 
to a note of an electronic notebook. 

15. The apparatus of daim 14, further comprising: 

means for automaticcilly adding to the note, in 
response to the request, primary design infor- 
mation corresponding to the design. 



means for receiving secondary design informa- 
tion corresponding to the design; and 
means for adding the secondary design infor- 
mation to the note; arKl preferal^y further conr 
prising 

means for aeating a graphical representation 
of a correspondence between the secondary 
design infonmation and a feature of the design. 

17. The apparatus of claim 14, wherein the means for 
automatically copying comprises means for auto- 
matically adding a dynamic design to the note, and 
wherein the apparatus further comprises means for 
accessing the design to otrtain a current version of 
the design each time the note is accessed. 



10 16. The apparatus of daim 14, further comprising: 



15 



20 



12. The apparatus of daim 10, wherein the second 
control logic is also to receive secondary design so 
information corresponding to the design, and add 
the secondary design information to the note; and 
preferably further comprising 



third control logic to create a graphical repre- 35 
sentation of a correspondence between the 
secondary design information and a feature of 
the design. 



13. The apparatus of daim 10. wherein the second 4o 
control logic is to copy a dynamic design to the 
note, and to access the design to obtain a current 
version of the design each time the note is 
accessed: and/or 

45 

wherein the second control logic is also to track 
design history by automatically copying a plu- 
rality of portions of the design to the note of the 
electronic notebook over a period of time, each 
of the plurality of portions being from a different so 
point in time. 



14. An apparatus for maintaining information ccMre- 
sponding to a design, the apparatus conrprising: 

means for receiving a request to add note infor- 
mation conresponcfing to the design; and 
means for automatically copying, in response 
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